package trastienda.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import trastienda.excepcion.DAOExcepcion;
import trastienda.modelo.Dispositivo;
import trastienda.util.ConexionBD;

public class DispositivoDAO extends BaseDAO {
	
	public void insertar(Dispositivo vo) throws DAOExcepcion {
		System.out.println("DispositivoDAO: insertar()");
		String query = "INSERT INTO dispositivo(usuario, codigo_gcm) VALUES (?,?)";
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, vo.getUsuario());
			stmt.setString(2, vo.getCodigoGCM());
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo insertar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
	}

	public Dispositivo obtenerCodigoGCMPorUsuario(String usuario) throws DAOExcepcion {
		System.out.println("DispositivoDAO: obtenerCodigoGCMPorUsuario()");
		Dispositivo vo = new Dispositivo();
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			String query = "SELECT codigo_gcm FROM dispositivo WHERE usuario=?";
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, usuario);
			rs = stmt.executeQuery();
			if (rs.next()) {
				vo.setCodigoGCM(rs.getString(1));
				vo.setUsuario(usuario);
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return vo;
	}

	public void actualizar(Dispositivo vo) throws DAOExcepcion {
		System.out.println("DispositivoDAO: actualizar(Dispositivo vo)");
		String query = "UPDATE dispositivo SET codigo_gcm=? where usuario=?";
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, vo.getCodigoGCM());
			stmt.setString(2, vo.getUsuario());
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo actualizar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
	}

}